diff options
| author | Factiven <[email protected]> | 2023-09-25 00:44:40 +0700 |
|---|---|---|
| committer | GitHub <[email protected]> | 2023-09-25 00:44:40 +0700 |
| commit | 1a85c2571690ba592ac5183d5eadaf9846fe532b (patch) | |
| tree | 3f3552c00cd49c0eeab5275275cf5cf5666e5027 /pages/api/v2/info/[id].js | |
| parent | Delete .github/workflows/deploy.yml (diff) | |
| download | moopa-4.1.0.tar.xz moopa-4.1.0.zip | |
Update v4.1.0 (#79)v4.1.0
* Update v4.1.0
* Update pages/_app.js
Diffstat (limited to 'pages/api/v2/info/[id].js')
| -rw-r--r-- | pages/api/v2/info/[id].js | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/pages/api/v2/info/[id].js b/pages/api/v2/info/[id].js index 41daa6e..243756c 100644 --- a/pages/api/v2/info/[id].js +++ b/pages/api/v2/info/[id].js @@ -1,5 +1,5 @@ import axios from "axios"; -import redis from "../../../../lib/redis"; +import { rateLimiterRedis, redis } from "@/lib/redis"; const API_KEY = process.env.API_KEY; @@ -19,6 +19,14 @@ export default async function handler(req, res) { const id = req.query.id; let cached; if (redis) { + try { + const ipAddress = req.socket.remoteAddress; + await rateLimiterRedis.consume(ipAddress); + } catch (error) { + return res.status(429).json({ + error: `Too Many Requests, retry after ${error.msBeforeNext / 1000}`, + }); + } cached = await redis.get(id); } if (cached) { |